

# LevelX<sup>TM</sup>

**User Guide** 

Renesas Synergy<sup>™</sup> Platform Synergy Software Synergy Software (SSP) Component

All information contained in these materials, including products and product specifications, represents information on the product at the time of publication and is subject to change by Renesas Electronics Corp. without notice. Please review the latest information published by Renesas Electronics Corp. through various means, including the Renesas Electronics Corp. website (http://www.renesas.com).

#### Notice

- 1. Descriptions of circuits, software and other related information in this document are provided only to illustrate the operation of semiconductor products and application examples. You are fully responsible for the incorporation or any other use of the circuits, software, and information in the design of your product or system. Renesas Electronics disclaims any and all liability for any losses and damages incurred by you or third parties arising from the use of these circuits, software, or information.
- Renesas Electronics hereby expressly disclaims any warranties against and liability for infringement or any other claims involving
  patents, copyrights, or other intellectual property rights of third parties, by or arising from the use of Renesas Electronics products or
  technical information described in this document, including but not limited to, the product data, drawings, charts, programs,
  algorithms, and application examples.
- 3. No license, express, implied or otherwise, is granted hereby under any patents, copyrights or other intellectual property rights of Renesas Electronics or others.
- 4. You shall not alter, modify, copy, or reverse engineer any Renesas Electronics product, whether in whole or in part. Renesas Electronics disclaims any and all liability for any losses or damages incurred by you or third parties arising from such alteration, modification, copying or reverse engineering.
- 5. Renesas Electronics products are classified according to the following two quality grades: "Standard" and "High Quality". The intended applications for each Renesas Electronics product depends on the product's quality grade, as indicated below.
  - "Standard": Computers; office equipment; communications equipment; test and measurement equipment; audio and visual equipment; home electronic appliances; machine tools; personal electronic equipment; industrial robots; etc.
  - "High Quality": Transportation equipment (automobiles, trains, ships, etc.); traffic control (traffic lights); large-scale communication equipment; key financial terminal systems; safety control equipment; etc.

Unless expressly designated as a high reliability product or a product for harsh environments in a Renesas Electronics data sheet or other Renesas Electronics document, Renesas Electronics products are not intended or authorized for use in products or systems that may pose a direct threat to human life or bodily injury (artificial life support devices or systems; surgical implantations; etc.), or may cause serious property damage (space system; undersea repeaters; nuclear power control systems; aircraft control systems; key plant systems; military equipment; etc.). Renesas Electronics disclaims any and all liability for any damages or losses incurred by you or any third parties arising from the use of any Renesas Electronics product that is inconsistent with any Renesas Electronics data sheet, user's manual or other Renesas Electronics document.

- 6. When using Renesas Electronics products, refer to the latest product information (data sheets, user's manuals, application notes, "General Notes for Handling and Using Semiconductor Devices" in the reliability handbook, etc.), and ensure that usage conditions are within the ranges specified by Renesas Electronics with respect to maximum ratings, operating power supply voltage range, heat dissipation characteristics, installation, etc. Renesas Electronics disclaims any and all liability for any malfunctions, failure or accident arising out of the use of Renesas Electronics products outside of such specified ranges.
- 7. Although Renesas Electronics endeavors to improve the quality and reliability of Renesas Electronics products, semiconductor products have specific characteristics, such as the occurrence of failure at a certain rate and malfunctions under certain use conditions. Unless designated as a high reliability product or a product for harsh environments in a Renesas Electronics data sheet or other Renesas Electronics document, Renesas Electronics products are not subject to radiation resistance design. You are responsible for implementing safety measures to guard against the possibility of bodily injury, injury or damage caused by fire, and/or danger to the public in the event of a failure or malfunction of Renesas Electronics products, such as safety design for hardware and software, including but not limited to redundancy, fire control and malfunction prevention, appropriate treatment for aging degradation or any other appropriate measures. Because the evaluation of microcomputer software alone is very difficult and impractical, you are responsible for evaluating the safety of the final products or systems manufactured by you.
- 8. Please contact a Renesas Electronics sales office for details as to environmental matters such as the environmental compatibility of each Renesas Electronics product. You are responsible for carefully and sufficiently investigating applicable laws and regulations that regulate the inclusion or use of controlled substances, including without limitation, the EU RoHS Directive, and using Renesas Electronics products in compliance with all these applicable laws and regulations. Renesas Electronics disclaims any and all liability for damages or losses occurring as a result of your noncompliance with applicable laws and regulations.
- 9. Renesas Electronics products and technologies shall not be used for or incorporated into any products or systems whose manufacture, use, or sale is prohibited under any applicable domestic or foreign laws or regulations. You shall comply with any applicable export control laws and regulations promulgated and administered by the governments of any countries asserting jurisdiction over the parties or transactions.
- 10. It is the responsibility of the buyer or distributor of Renesas Electronics products, or any other party who distributes, disposes of, or otherwise sells or transfers the product to a third party, to notify such third party in advance of the contents and conditions set forth in this document.
- 11. This document shall not be reprinted, reproduced or duplicated in any form, in whole or in part, without prior written consent of Renesas Electronics.
- 12. Please contact a Renesas Electronics sales office if you have any questions regarding the information contained in this document or Renesas Electronics products.
- (Note 1) "Renesas Electronics" as used in this document means Renesas Electronics Corporation and also includes its directly or indirectly controlled subsidiaries.
- (Note 2) "Renesas Electronics product(s)" means any product developed or manufactured by or for Renesas Electronics.

# Renesas Synergy Specific Information

If you are using LevelX for the Renesas Synergy platform, please use the following information.

# **Customer Support Center**

For Renesas Synergy platform support, please contact Renesas directly:

Support: <a href="https://renesassynergy.com/support">https://renesassynergy.com/support</a>

#### Installation and Use of LevelX

**Page 5:** If you are using Renesas Synergy SSP and the e<sup>2</sup> studio ISDE, LevelX will already be installed. You can ignore the Installation section.

# **NAND Support**

Pages 8-36: Support for NAND memory is not available in SSP v1.5.0.

# L E V E L

# User Guide

**V5** 

**Express Logic, Inc.** 

858.613.6640 Toll Free 888.THREADX FAX 858.521.4259

www.expresslogic.com

#### ©1997-2018 by Express Logic, Inc.

All rights reserved. This document and the associated ThreadX software are the sole property of Express Logic, Inc. Each contains proprietary information of Express Logic, Inc. Reproduction or duplication by any means of any portion of this document without the prior written consent of Express Logic, Inc. is expressly forbidden. Express Logic, Inc. reserves the right to make changes to the specifications described herein at any time and without notice in order to improve design or reliability of ThreadX. The information in this document has been carefully checked for accuracy; however, Express Logic, Inc. makes no warranty pertaining to the correctness of this document.

#### **Trademarks**

ThreadX is a registered trademark of Express Logic, Inc., and *picokernel*, *preemption-threshold*, and *event-chaining* are trademarks of Express Logic, Inc.

All other product and company names are trademarks or registered trademarks of their respective holders.

#### **Warranty Limitations**

Express Logic, Inc. makes no warranty of any kind that the ThreadX products will meet the USER's requirements, or will operate in the manner specified by the USER, or that the operation of the ThreadX products will operate uninterrupted or error free, or that any defects that may exist in the ThreadX products will be corrected after the warranty period. Express Logic, Inc. makes no warranties of any kind, either expressed or implied, including but not limited to the implied warranties of merchantability and fitness for a particular purpose, with respect to the ThreadX products. No oral or written information or advice given by Express Logic, Inc., its dealers, distributors, agents, or employees shall create any other warranty or in any way increase the scope of this warranty, and licensee may not rely on any such information or advice.

Part Number: 000-0021 Revision 5.4

# **Contents**

| Contents                            | 3   |
|-------------------------------------|-----|
| Chapter 1 Overview                  | 4   |
| Chapter 2 Installation and Use      | 5   |
| Chapter 3 LevelX NAND Support       | 8   |
| NAND Bad Block Support              | .10 |
| NAND Driver Requirements            | .10 |
| Driver Initialization               | .10 |
| Driver Read Page                    | .11 |
| Driver Write Page                   |     |
| Driver Block Erase                  | .11 |
| Driver Block Erased Verify          | .12 |
| Driver Page Erased Verify           | .12 |
| Driver Block Status Get             |     |
| Driver Block Status Set             |     |
| Driver Block Extra Bytes Get        |     |
| Driver Block Extra Bytes Set        |     |
| Driver System Error                 |     |
| NAND Simulated Driver               |     |
| NAND FileX Integration              |     |
| Chapter 4 LevelX NAND APIs          |     |
| lx_nand_flash_close                 |     |
| lx_nand_flash_defragment            |     |
| lx_nand_flash_extended_cache_enable |     |
| lx_nand_flash_initialize            |     |
| lx_nand_flash_open                  |     |
| lx_nand_flash_page_ecc_check        |     |
| lx_nand_flash_page_ecc_compute      |     |
| lx_nand_flash_sector_read           |     |
| lx_nand_flash_sector_release        |     |
| lx_nand_flash_sector_write          |     |
| Chapter 5 LevelX NOR Support        |     |
| Chapter 6 LevelX NOR APIs           |     |
| lx_nor_flash_close                  |     |
| lx_nor_flash_defragment             |     |
| lx_nor_flash_initialize             |     |
| lx_nor_flash_open                   |     |
| lx_nor_flash_sector_read            |     |
| lx_nor_flash_sector_release         |     |
| lx_nor_flash_sector_write           |     |
| Index                               | .58 |

# Chapter 1

# **Overview**

LevelX provides NAND and NOR flash wear leveling facilities to embedded applications. Since both NAND and NOR flash memory can only be erased a finite number of times, it's critical to distribute the flash memory use evenly. This is typically called "wear leveling" and is the purpose behind LevelX.

The algorithm that chooses which flash block to reuse is primarily based on the erase count, but not entirely. The block with the lowest erase count might not be chosen if there is another block that has an erase count within an acceptable delta from the minimal erase count and that has a greater number of obsolete mappings. In such cases, the block with the greatest number of obsolete mappings will be erased and reused, thus saving overhead in moving valid mapping entries.

LevelX supports multiple instances of NAND and/or NOR parts, i.e., the application can utilize separate instances of LevelX within the same application. Each instance requires its own control block provided by the application as well as its own flash driver.

LevelX presents to the user an array of logical sectors that are mapped to physical flash memory inside of LevelX. To enhance performance, LevelX also provides a cache of the most recent logical sector mappings. The size of this cache is user defined. Applications may use LevelX in conjunction with FileX or may read/write logical sectors directly. LevelX has no dependency on FileX and very little dependency on ThreadX (only primitive ThreadX data types are used).

LevelX is designed for fault tolerance. Flash updates are performed in a multiple-step process that can be interrupted in each step. LevelX automatically recovers to the optimal state during the next operation.

LevelX requires a flash driver for physical access to the underlying flash memory. Example NAND and NOR simulated drivers are provided and can be used as a good starting point for implementing actual LevelX drivers. In addition, driver requirements are detailed later in this documentation.

The following chapters describe the functional operation for the NAND and NOR LevelX support.

# Chapter 2

# Installation and Use

Installation and use of LevelX is straightforward and described in the following sections of this chapter.

#### Distribution

LevelX is distributed in ANSI C where each function is contained in its own separate C file. The files in the LevelX distribution are as follows:

```
lx api.h
lx_nand_flash_256byte_ecc_check.c
lx_nand_flash_256byte_ecc_compute.c
lx nand flash block full update.c
lx_nand_flash_block_reclaim.c
lx_nand_flash_close.c
lx nand flash defragment.c
lx_nand_flash_extended_cache_enable.c
lx nand flash initialize.c
lx nand flash logical sector find.c
lx nand flash next block to erase find.c
lx_nand_flash_open.c
lx nand flash page ecc check.c
lx nand flash_page_ecc_compute.c
lx_nand_flash_physical_page_allocate.c
lx_nand_flash_sector_mapping_cache_invalidate.c
lx_nand_flash_sector_read.c
lx nand flash sector release.c
lx_nand_flash_sector_write.c
lx nand flash system error.c
lx nor flash block reclaim.c
lx nor flash close.c
lx_nor_flash_defragment.c
lx_nor_flash_initialize.c
lx nor flash logical sector find.c
lx_nor_flash_next_block_to_erase_find.c
lx nor flash open.c
lx nor_flash_physical_sector_allocate.c
lx nor flash sector mapping cache invalidate.c
lx_nor_flash_sector_read.c
lx nor flash sector release.
lx nor flash sector write.c
lx_nor_flash_system_error.c
```

There are also simulator and FileX driver samples for both LevelX NAND and NOR instances, as follows:

```
demo_filex_nand_flash.c
fx_nand_flash_simulated_driver.c
lx_nand_flash_simulator.c
demo_filex_nor_flash.c
fx_nor_flash_simulated_driver.c
```

Of course, if only NAND flash is required, only the LevelX NAND flash files (*Ix\_nand\_\*.c*) are needed. Similarly, if only NOR flash is required, only the NOR flash files (*Ix\_nor\_\*.c*) are needed.

# **Configuration Options**

LevelX can be configured at compile time via the conditional defines described below. Simply add the desired define to the compilation of each LevelX source to use the option.

| Define                              | Meaning                                         |
|-------------------------------------|-------------------------------------------------|
| LX_DIRECT_READ                      | Defined, this option bypasses the               |
|                                     | NOR flash driver read routine in                |
|                                     | favor or reading the NOR                        |
|                                     | memory directly, resulting in a                 |
|                                     | significant performance increase.               |
| LX_FREE_SECTOR_DATA_VERIFY          | Defined, this causes the LevelX                 |
|                                     | NOR instance open logic to verify               |
|                                     | free NOR sectors are all ones.                  |
| LX_NAND_SECTOR_MAPPING_CACHE_SIZE   | By default this value is 16 and                 |
|                                     | defines the logical sector                      |
|                                     | mapping cache size. Large                       |
|                                     | values improve performance, but                 |
|                                     | cost memory. The minimum size                   |
|                                     | is 8 and all values must be a                   |
| LV NAME FLACIL DIRECT MARRING CACLE | power of 2.                                     |
| LX_NAND_FLASH_DIRECT_MAPPING_CACHE  | Defined, this creates a direct                  |
|                                     | mapping cache, such that there                  |
|                                     | are no cache misses. It also                    |
|                                     | requires that LX_NAND_SECTOR_MAPPING_CACHE_SIZE |
|                                     | represents the exact number of                  |
|                                     | total pages in your flash device.               |
| LX_NOR_SECTOR_MAPPING_CACHE_SIZE    | By default this value is 16 and                 |
|                                     | defines the logical sector                      |
|                                     | mapping cache size. Large                       |
|                                     | values improve performance, but                 |
|                                     | cost memory. The minimum size                   |
|                                     | is 8 and all values must be a                   |
|                                     | power of 2.                                     |
| LX_THREAD_SAFE_ENABLE               | Defined, this makes LevelX                      |
|                                     | thread-safe by using a ThreadX                  |

|  | mutex obi | ect throug | hout the API. |
|--|-----------|------------|---------------|
|--|-----------|------------|---------------|

# **Using LevelX**

Using LevelX by itself or with FileX is easy. Simply include *lx\_api.h* in the code that references the LevelX API and ensure that the LevelX object code is available at link time. Please examine the *demo\_filex\_nand\_flash.c* and *demo\_filex\_nor\_flash.c* for examples of how to use LevelX.

# **Chapter 3**

# LevelX NAND Support

NAND flash memory is commonly utilized for large data storage, which is typical of file systems. NAND memory consists of *blocks*. Within each NAND block is a series of *pages*. NAND blocks are erasable, which means that all pages within the NAND block are erased (set to all ones). Each NAND block page has a set of *spare bytes* that are utilized by LevelX for bookkeeping, bad block management, and error detection. NAND block pages are available in a variety of sizes. The most common page sizes are:

Page Size Spare Bytes

| 256  | 8  |
|------|----|
| 512  | 16 |
| 2048 | 64 |

NAND memory differs from NOR memory in that there is no direct access, i.e., NAND memory cannot be read directly from the processor like NOR memory. NAND memory can only be written to after an erase a limited number of times. Again, this differs from NOR memory that can be written an unlimited number of times providing the write request is clearing set bits. Finally, the spare bytes associated with each page are unique to NAND flash. Typical spare byte configurations are:

| <b>Number of Spare By</b> | rtes Format |
|---------------------------|-------------|
|---------------------------|-------------|

| 8  | Bytes 0-2:     | ECC bytes             |
|----|----------------|-----------------------|
|    | Bytes 3,4,6,7: | LevelX Sector Mapping |
|    | Byte 5:        | Bad block flag        |
|    | Bytes 0-3,6-7: | ECC bytes             |
| 16 | Bytes 8-11:    | LevelX Sector Mapping |
| 16 | Bytes 12-15:   | Unused                |
|    | Byte 5:        | Bad block flag        |
| 64 | Byte 0:        | Bad block flag        |
|    | Bytes 2-5:     | LevelX Sector Mapping |
|    | Bytes 6-39:    | Unused                |
|    | Bytes 40-63:   | ECC bytes             |

LevelX Utilizes 4 of the spare bytes of each NAND page for keeping track of the logical sector mapped to the physical NAND page. These 4 bytes are used to implement a 32-bit unsigned integer with a LevelX proprietary format. The upper bit of the 32-bit field (bit 31) is used to indicate the logical sector-to-page mapping is valid. If this bit is 0, the information in this page is no longer valid. The next bit—bit 30—is used to indicate this page is in the process of becoming obsolete and a new sector is being written. Bit 29 is used to indicate when the mapping entry write is complete. If bit 29 is 0, the mapping entry write is complete. If bit 29 is set, the mapping entry was in the process of being written. Bits 30 and 29 are used in recovering from a potential power loss while updating a new flash page. Finally, the lower 29-bits (28-0) contain the logical sector number for the page.

#### **LevelX Mapping Entry**

| Bit(s) | Meaning                                                             |
|--------|---------------------------------------------------------------------|
| 31     | Valid flag. When set and logical sector is not all ones indicates   |
|        | mapping is valid                                                    |
| 30     | Obsolete flag. When clear, this mapping is either obsolete or is in |
|        | the process of becoming obsolete.                                   |
| 29     | Mapping entry write is complete when this bit is 0                  |
| 0-28   | Logical sector mapped to this physical page—when not all ones.      |

LevelX also utilizes the first page of each NAND block for the block erase count as well as the list of mapped pages when the block is full. The format of the first page of a NAND block in LevelX is shown below:

#### **LevelX Block Page 0 Format**

[Block Erase Count]
[Page 1 Sector Mapping]

. . .

[Page "n" Sector Mapping] [0xF0F0F0F0]

**Note**: The page mapping information is only written when the block is full, i.e., all the pages of the block have been written to. This enables faster search for free pages and logical sector mapping during run-time.

# NAND Bad Block Support

NAND memory is also more likely to have bad blocks than NOR memory. This is largely because NAND manufacturers can increase yield by allowing bad blocks and requiring software to work-around such bad blocks. LevelX handles NAND bad block management by simply mapping around bad blocks.

LevelX also provides APIs for 256-byte Hamming Error Correction Codes (ECC) for the underlying LevelX driver to utilize for calculating new ECC codes or to perform 1-bit error correction on page reading within each 256-byte section of the page.

### **NAND Driver Requirements**

LevelX requires an underlying NAND flash driver that is specific to the underlying flash part and hardware implementation. The driver is specified to LevelX during initialization via the API *Ix\_nand\_flash\_open*. The prototype of the LevelX driver is:

```
INT nand_driver_initialize(LX NAND FLASH *instance);
```

The "*instance*" parameter specifies the LevelX NAND control block. The driver initialization function is responsible for setting up all the other driver-level services for the associated LevelX instance. The services required for each LevelX NAND instance are:

Read Page
Write Page
Block Erase
Block Erased Verify
Page Erased Verify
Block Status Get
Block Status Set
Block Extra Bytes Get
Block Extra Bytes Set
System Error Handler

### **Driver Initialization**

These services are setup via setting function pointers in the LX\_NAND\_FLASH instance within the driver's initialization function. The driver initialization function also specifies the total number of block, pages per block, bytes per page, and a RAM area large enough to read one page into memory. The driver initialization function likely also performs additional device and/or implementation-specific initialization duties before returning **LX\_SUCCESS**.

# **Driver Read Page**

The LevelX NAND driver "read page" service is responsible for reading a specific page in a specific block of the NAND flash. All error checking and correcting logic is the responsibility of the driver service. If successful, the LevelX NAND driver returns *LX\_SUCCESS*. If not successful, the LevelX NAND driver returns *LX\_ERROR*. The prototype of the LevelX NAND driver "read page" service is:

Where "block" and "page" identify which page to read and "destination" and "words" specify where to place the page contents and how many 32-bit words to read.

# **Driver Write Page**

The LevelX NAND driver "write page" service is responsible for writing a specific page into the specified block of the NAND flash. All error checking and ECC computation is the responsibility of the driver service. If successful, the LevelX NAND driver returns *LX\_SUCCESS*. If not successful, the LevelX NAND driver returns *LX\_ERROR*. The prototype of the LevelX NAND driver "write page" service is:

Where "block" and "page" identify which page to write and "source" and "words" specify the source of the write and how many 32-bit words to write.

**Note**: LevelX relies on the driver for low-level error detection when writing to the flash page, which typically involves reading back the page and comparing with the write buffer to ensure the write was successful.

#### **Driver Block Erase**

The LevelX NAND driver "block erase" service is responsible for erasing the specified block of the NAND flash. If successful, the LevelX NAND

driver returns *LX\_SUCCESS*. If not successful, the LevelX NAND driver returns *LX\_ERROR*. The prototype of the LevelX NAND driver "block erase" service is:

Where "block" identifies which block to erase. The parameter "erase\_count" is provided for diagnostic purposes. For example, the driver may want to alert another portion of the application software when the erase count exceeds a specific threshold.

**Note**: LevelX relies on the driver for low-level error detection when the block is erased, which typically involves ensuring that all pages of the block are all ones.

# **Driver Block Erased Verify**

The LevelX NAND driver "block erased verify" service is responsible for verifying that the specified block of the NAND flash is erased. If it is erased, the LevelX NAND driver returns *LX\_SUCCESS*. If the block is not erased, the LevelX NAND driver returns *LX\_ERROR*. The prototype of the LevelX NAND driver "block erased verify" service is:

```
INT nand driver block erased verify(ULONG block);
```

Where "block" specifies which block to verify that it is erased.

**Note**: LevelX relies on the driver to examine all pages and all bytes of each page – including spare and data bytes – to ensure they are erased (contain all ones).

### **Driver Page Erased Verify**

The LevelX NAND driver "page erased verify" service is responsible for verifying that the specified page of the specified block of the NAND flash is erased. If it is erased, the LevelX NAND driver returns *LX\_SUCCESS*. If the page is not erased, the LevelX NAND driver returns *LX\_ERROR*. The prototype of the LevelX NAND driver "page erased verify" service is:

Where "**block**" specifies which block and "**page**" specifies the page to verify that it is erased.

**Note**: LevelX relies on the driver to examine all bytes of the specified page – including spare and data bytes – to ensure they are erased (contain all ones).

#### **Driver Block Status Get**

The LevelX NAND driver "block status get" service is responsible for retrieving the bad block flag of the specified block of the NAND flash. If it is successful, the LevelX NAND driver returns *LX\_SUCCESS*. If it is not successful, the LevelX NAND driver returns *LX\_ERROR*. The prototype of the LevelX NAND driver "block status get" service is:

Where "block" specifies which block and "bad\_block\_byte" specifies the destination for the bad block flag.

### **Driver Block Status Set**

The LevelX NAND driver "block status set" service is responsible for setting the bad block flag of the specified block of the NAND flash. If it is successful, the LevelX NAND driver returns *LX\_SUCCESS*. If it is not successful, the LevelX NAND driver returns *LX\_ERROR*. The prototype of the LevelX NAND driver "block status set" service is:

Where "block" specifies which block and "bad\_block\_byte" specifies the value of the bad block flag.

# **Driver Block Extra Bytes Get**

The LevelX NAND driver "block extra bytes get" service is responsible for retrieving extra bytes associated with a specific page of a specific block of the NAND flash. If it is successful, the LevelX NAND driver returns **LX\_SUCCESS**. If it is not successful, the LevelX NAND driver returns **LX\_ERROR**. The prototype of the LevelX NAND driver "block extra bytes get" service is:

Where "block" specifies which block, "page" specifies the specific page and "destination" specifies the destination for the extra bytes. The parameter "size" specifies how many extra bytes to get.

# **Driver Block Extra Bytes Set**

The LevelX NAND driver "block extra bytes set" service is responsible for setting extra bytes in a specific page of a specific block of the NAND flash. If it is successful, the LevelX NAND driver returns **LX\_SUCCESS**. If it is not successful, the LevelX NAND driver returns **LX\_ERROR**. The prototype of the LevelX NAND driver "block extra bytes set" service is:

Where "block" specifies which block, "page" specifies the specific page and "source" specifies the source of the extra bytes. The parameter "size" specifies how many extra bytes to set.

# **Driver System Error**

The LevelX NAND driver "system error handler" service is responsible for setting handling system errors detected by LevelX. The processing in this routine is application dependent. If it is successful, the LevelX NAND driver returns *LX\_SUCCESS*. If it is not successful, the LevelX NAND driver returns *LX\_ERROR*. The prototype of the LevelX NAND driver "system error" service is:

Where "**block**" specifies which block, and "**page**" specifies the specific page the error represented by "**error\_code**" occurred.

### **NAND Simulated Driver**

LevelX provides a simulated NAND flash driver that simply uses RAM to simulate the operation of a NAND flash part. By default, the NAND simulated driver provides 8 NAND flash blocks with 16 pages per block and 2048 bytes per page.

The simulated NAND flash driver initialization function is Ix\_nand\_flash\_simulator\_initialize and is defined in Ix\_nand\_flash\_simulator.c. This driver also provides a good template for writing specific NAND flash drivers.

# **NAND FileX Integration**

As mentioned earlier, LevelX does not rely on FileX for operation. All the LevelX APIs may be called directly by the application software to store/retrieve raw data to the logical sectors provided by LevelX. However, LevelX also supports FileX.

The file <code>fx\_nand\_flash\_simulated\_driver.c</code> contains an example FileX driver for use with the NAND flash simulation. An interesting aspect of this driver is that it combines 512-byte logical sectors typically used by FileX into single logical sector read/write requests to the LevelX simulator using 2048-byte pages. This results in more efficient use of the NAND flash memory. The NAND flash FileX driver for LevelX provides a good starting point for writing custom FileX drivers.

**Note**: The FileX NAND flash format should be one full block size of sectors less than the NAND flash provides. This will help ensure best performance during the wear level processing. Additional techniques to improve write performance in the LevelX wear leveling algorithm include:

- 1. Ensure that all writes are exactly one or more clusters in size and start on exact cluster boundaries.
- Pre-allocate clusters before performing large file write operations via the FileX fx\_file\_allocate class of APIs.
- 3. Ensure the FileX driver is enabled to receive release sector information and requests made to the driver to release sectors are handled in the driver by calling <code>lx\_nor\_flash\_sector\_release</code>.
- Periodic use of *Ix\_nand\_flash\_defragment* to free up as many NAND blocks as possible and thus improve write performance.
- Utilize the *Ix\_nand\_flash\_extended\_cache\_enable* API to provide a RAM cache of various NAND block resources for faster performance.

# Chapter 4

# **LevelX NAND APIS**

The LevelX NAND APIs available to the application are:

Ix\_nand\_flash\_close
 Close NAND flash instance

Ix\_nand\_flash\_defragment

Defragment NAND flash instance

Ix\_nand\_flash\_extended\_cache\_enable

Enable/disable extended NAND cache

Ix\_nand\_flash\_initialize
Initialize NAND flash support

Ix\_nand\_flash\_open
Open NAND flash instance

Ix\_nand\_flash\_page\_ecc\_check
Check page for ECC errors with correction

Ix\_nand\_flash\_page\_ecc\_compute

Computes ECC for page

Ix\_nand\_flash\_sector\_read
Read NAND flash sector

Ix\_nand\_flash\_sector\_release
Release NAND flash sector

Ix\_nand\_flash\_sector\_write
Write NAND flash sector

# lx\_nand\_flash\_close

Close NAND flash instance

#### **Prototype**

UINT lx\_nand\_flash\_close(LX\_NAND\_FLASH \*nand\_flash);

#### **Description**

This service closes the previously opened NAND flash instance.

#### **Input Parameters**

nand\_flash NAND flash instance pointer.

#### **Return Values**

**LX\_SUCCESS** (0x00) Successful request.

**LX\_ERROR** (0x01) Error closing flash instance.

**Threads** 

#### Example

```
/* Close NAND flash instance "my_nand_flash". */
status = lx_nand_flash_close(&my_nand_flash);
/* If status is LX SUCCESS the request was successful. */
```

```
Ix_nand_flash_defragment, Ix_nand_flash_extended_cache_enable, Ix_nand_flash_initialize, Ix_nand_flash_open, Ix_nand_flash_page_ecc_check, Ix_nand_flash_page_ecc_compute, Ix_nand_flash_sector_read, Ix_nand_flash_sector_release, Ix_nand_flash_sector_write
```

# lx\_nand\_flash\_defragment

Defragment NAND flash instance

#### **Prototype**

UINT lx\_nand\_flash\_defragment(LX\_NAND\_FLASH \*nand\_flash);

#### **Description**

This service defragments the previously opened NAND flash instance. The defragment process maximizes the number of free pages and blocks.

#### **Input Parameters**

nand\_flash NAND flash instance pointer.

#### **Return Values**

**LX\_SUCCESS** (0x00) Successful request.

**LX\_ERROR** (0x01) Error defragmenting flash

instance.

**Threads** 

#### Example

```
/* Defragment NAND flash instance "my_nand_flash". */
status = lx_nand_flash_defragment(&my_nand_flash);
/* If status is LX SUCCESS the request was successful. */
```

```
Ix_nand_flash_close, Ix_nand_flash_extended_cache_enable, Ix_nand_flash_initialize, Ix_nand_flash_open, Ix_nand_flash_page_ecc_check, Ix_nand_flash_page_ecc_compute, Ix_nand_flash_sector_read, Ix_nand_flash_sector_release, Ix_nand_flash_sector_write
```

### Ix\_nand\_flash\_extended\_cache\_enable

Enable/disable extended NAND cache

#### **Prototype**

```
UINT lx_nand_flash_extended_cache_enable(LX_NAND_FLASH *nand_flash, VOID *memory, ULONG size);
```

#### **Description**

This service implements a cache layer in RAM using the memory supplied by the application. The total amount of memory required for full cache operation can be calculated as follows:

If the supplied memory is not large enough to accommodate the full NAND cache, this routine will enable as much of the NAND flash cache as possible based on the memory supplied.

The NAND cache is disabled if the memory address specified is NULL. Hence, the NAND cache maybe be used in a temporary fashion.

#### **Input Parameters**

| nand_flash | NAND flash instance pointer.           |
|------------|----------------------------------------|
| memory     | Starting address for cache memory.     |
|            | A value of LX_NULL disables the cache. |
| size       | The size in bytes of the memory        |
|            | supplied.                              |

#### **Return Values**

| LX_SUCCESS | (0x00) | Successful request.        |
|------------|--------|----------------------------|
| LX_ERROR   | (0x01) | Not enough memory for one  |
|            |        | element of the NAND cache. |

**Threads** 

#### **Example**

```
Ix_nand_flash_close, Ix_nand_flash_defragment, Ix_nand_flash_initialize, Ix_nand_flash_open, Ix_nand_flash_page_ecc_check, Ix_nand_flash_page_ecc_compute, Ix_nand_flash_sector_read, Ix_nand_flash_sector_release, Ix_nand_flash_sector_write
```

# Ix\_nand\_flash\_initialize

Initialize NAND flash support

#### **Prototype**

UINT lx\_nand\_flash\_initialize(void);

#### **Description**

This service initializes LevelX NAND flash support. It must be called before any other LevelX NAND APIs.

#### **Input Parameters**

**None** 

#### **Return Values**

LX\_SUCCESS (0x00) Successful request.
LX\_ERROR (0x01) Error initializing NAND flash support.

Initialization, Threads

#### Example

```
/* Initialize NAND flash support. */
status = lx_nand_flash_initialize();
/* If status is LX SUCCESS the request was successful. */
```

```
lx_nand_flash_close, lx_nand_flash_defragment,
lx_nand_flash_extended_cache_enable, lx_nand_flash_open,
lx_nand_flash_page_ecc_check, lx_nand_flash_page_ecc_compute,
lx_nand_flash_sector_read, lx_nand_flash_sector_release,
lx_nand_flash_sector_write
```

# Ix\_nand\_flash\_open

Open NAND flash instance

#### **Prototype**

#### Description

This service opens a NAND flash instance with the specified NAND flash control block and driver initialization function. Note that the driver initialization function is responsible for installing various function pointers for reading, writing, and erasing blocks/pages of the NAND hardware associated with this NAND flash instance.

#### **Input Parameters**

| nand_flash             | NAND flash instance pointer.             |
|------------------------|------------------------------------------|
| name                   | Name of NAND flash instance.             |
| nand_driver_initialize | Function pointer to NAND flash driver    |
|                        | initialization function. Please refer to |
|                        | Chapter 2 of this guide for more details |

Chapter 3 of this guide for more details on NAND flash driver responsibilities.

#### **Return Values**

| LX_SUCCESS   | (0x00) | Successful request.               |
|--------------|--------|-----------------------------------|
| LX_ERROR     | (0x01) | Error opening NAND flash          |
|              |        | instance.                         |
| LX_NO_MEMORY | (80x0) | Driver did not provide buffer for |
|              |        | reading one page into RAM.        |

**Threads** 

#### **Example**

```
lx_nand_flash_close, lx_nand_flash_defragment, lx_nand_flash_extended_cache_enable, lx_nand_flash_initialize, lx_nand_flash_page_ecc_check, lx_nand_flash_page_ecc_compute, lx_nand_flash_sector_read, lx_nand_flash_sector_release, lx_nand_flash_sector_write
```

# lx\_nand\_flash\_page\_ecc\_check

Check page for ECC errors with correction

#### **Prototype**

#### Description

This service verifies the integrity of the supplied NAND page buffer with the supplied ECC. Page size (defined in the NAND flash instance pointer) is assumed to be a multiple of 256-bytes and the ECC code supplied is capable of correcting a 1 bit error in each 256-byte portion of the page.

#### **Input Parameters**

| nand_flash  | NAND flash instance pointer.        |
|-------------|-------------------------------------|
| page_buffer | Pointer to NAND flash page buffer.  |
| ecc_buffer  | Pointer to ECC for NAND flash page. |
|             | Note that there are 3 ECC bytes per |
|             | 256-byte portion of the page.       |

#### **Return Values**

| LX_SUCCESS              | (0x00) | NAND page has no errors. |  |  |  |
|-------------------------|--------|--------------------------|--|--|--|
| LX_NAND_ERROR_CORRECTED |        |                          |  |  |  |

(0x06) One or more 1-bit errors were corrected in the NAND page—correction(s) are in the page buffer.

LX\_NAND\_ERROR\_NOT\_CORRECTED

(0x07) Too many errors to correct on the NAND page.

LevelX Driver

#### **Example**

```
lx_nand_flash_close, lx_nand_flash_defragment,
lx_nand_flash_extended_cache_enable, lx_nand_flash_initialize,
lx_nand_flash_open, lx_nand_flash_page_ecc_compute,
lx_nand_flash_sector_read, lx_nand_flash_sector_release,
lx_nand_flash_sector_write
```

# Ix\_nand\_flash\_page\_ecc\_compute

Compute ECC for page

#### **Prototype**

UINT **lx\_nand\_flash\_page\_ecc\_compute**(LX\_NAND\_FLASH \*nand\_flash, UCHAR \*page\_buffer, UCHAR \*ecc\_buffer);

#### **Description**

This service computes the ECC of the supplied NAND page buffer and returns the ECC in the supplied ECC buffer. Page size is assume to be a multiple of 256-bytes (defined in the NAND flash instance pointer). The ECC code is used to verify the integrity of the page when it is read at a later time.

#### **Input Parameters**

| nand_ | _flash  |
|-------|---------|
| page_ | _buffer |
| ecc_b | uffer   |

NAND flash instance pointer.
Pointer to NAND flash page buffer.
Pointer to destination for ECC of the
NAND flash page. Note that must be 3
bytes of ECC storage per 256-byte
portion of the page. For example, a
2048 byte page would require 24 bytes
for the ECC.

#### **Return Values**

LX\_SUCCESS LX\_ERROR (0x00) ECC successfully calculated.

(0x01) Error calculating ECC.

LevelX Driver

#### **Example**

```
lx_nand_flash_close, lx_nand_flash_defragment,
lx_nand_flash_extended_cache_enable, lx_nand_flash_initialize,
lx_nand_flash_open, lx_nand_flash_page_ecc_check,
lx_nand_flash_sector_read, lx_nand_flash_sector_release,
lx_nand_flash_sector_write
```

### lx\_nand\_flash\_sector\_read

Read NAND flash sector

#### **Prototype**

UINT **lx\_nand\_flash\_sector\_read**(LX\_NAND\_FLASH \*nand\_flash, ULONG logical\_sector, VOID \*buffer);

#### Description

This service reads the logical sector from the NAND flash instance and if successful returns the contents in the supplied buffer. Note that NAND sector size is always the page size of the underlying NAND hardware.

#### **Input Parameters**

nand\_flashNAND flash instance pointer.logical\_sectorLogical sector to read.

buffer Pointer to destination for contents of the

logical sector. Note that the buffer is assumed to be the size of the NAND

flash page size.

#### **Return Values**

**LX\_SUCCESS** (0x00) Successful request.

**LX\_ERROR** (0x01) Error reading NAND flash

sector.

**Threads** 

#### **Example**

```
lx_nand_flash_close, lx_nand_flash_defragment,
lx_nand_flash_extended_cache_enable, lx_nand_flash_initialize,
lx_nand_flash_open, lx_nand_flash_page_ecc_check,
lx_nand_flash_page_ecc_compute, lx_nand_flash_sector_release,
lx_nand_flash_sector_write
```

# Ix\_nand\_flash\_sector\_release

Release NAND flash sector

#### **Prototype**

```
UINT lx_nand_flash_sector_release(LX_NAND_FLASH *nand_flash, ULONG logical_sector);
```

#### **Description**

This service releases the logical sector mapping in the NAND flash instance. Releasing a logical sector when not used makes the LevelX wear leveling more efficient.

#### **Input Parameters**

| nand_flash     | NAND flash instance pointer. |
|----------------|------------------------------|
| logical_sector | Logical sector to release.   |

#### **Return Values**

| LX_SUCCESS | (0x00) | Successful request. |
|------------|--------|---------------------|
|            |        |                     |

**LX\_ERROR** (0x01) Error NAND flash sector write.

**Threads** 

## **Example**

```
/* Release logical sector 20 of the NAND flash instance
   "my_nand_flash". */
status = lx_nand_flash_sector_release(&my_nand_flash, 20);
/* If status is LX_SUCCESS, logical sector 20 has been
   released. */
```

#### See Also

lx\_nand\_flash\_close, lx\_nand\_flash\_defragment,
lx\_nand\_flash\_extended\_cache\_enable, lx\_nand\_flash\_initialize,
lx\_nand\_flash\_open, lx\_nand\_flash\_page\_ecc\_check,
lx\_nand\_flash\_page\_ecc\_compute, lx\_nand\_flash\_sector\_read,
lx\_nand\_flash\_sector\_write

## Ix\_nand\_flash\_sector\_write

Write NAND flash sector

## **Prototype**

UINT **lx\_nand\_flash\_sector\_write**(LX\_NAND\_FLASH \*nand\_flash, ULONG logical\_sector, VOID \*buffer);

#### **Description**

This service writes the specified logical sector in the NAND flash instance.

#### **Input Parameters**

nand\_flashNAND flash instance pointer.logical\_sectorLogical sector to write.bufferPointer to the contents of the logicalsector. Note that the buffer is assum.

sector. Note that the buffer is assumed to be the size of the NAND flash page

size.

#### **Return Values**

LX\_SUCCESS (0x00) Successful request.

LX\_NO\_SECTORS (0x02) No more free sectors are available to perform the write.

LX\_ERROR (0x01) Error releasing NAND flash sector.

**Threads** 

#### **Example**

#### See Also

lx\_nand\_flash\_close, lx\_nand\_flash\_defragment,
lx\_nand\_flash\_extended\_cache\_enable, lx\_nand\_flash\_initialize,
lx\_nand\_flash\_open, lx\_nand\_flash\_page\_ecc\_check,
lx\_nand\_flash\_page\_ecc\_compute, lx\_nand\_flash\_sector\_read,
lx\_nand\_flash\_sector\_release

# Chapter 5

# **LevelX NOR Support**

NOR flash memory is composed of *blocks* that are typically evenly divisible by 512 bytes. There are no concept of a flash *page* in NOR flash memory. Also, there are no *spare* bytes in NOR flash memory, hence LevelX must use the NOR flash memory itself for all management information. Direct read access is possible in NOR flash memory. Write access typically requires a special sequence of operations. NOR flash memory may be written to multiple times, providing that bits are being cleared. Bits in NOR flash memory can only be set once, via the erase block operation.

LevelX divides each NOR flash block into 512-byte logical **sectors**. Furthermore, LevelX uses the first "n" sectors of each NOR flash block to store management information. The format of the LevelX NOR flash memory management information is:

#### **LevelX NOR Block Format**

| Byte Offset | Contents                   |  |
|-------------|----------------------------|--|
| 0           | [Block Erase Count]        |  |
| 4           | [Minimum Mapped Sector]    |  |
| 8           | [Maximum Mapped Sector]    |  |
| 12          | [Free Sector Bit Map]      |  |
| m           | [Sector 0 Mapping Entry]   |  |
|             | •••                        |  |
| m+4*(n-1)   | [Sector "n" Mapping Entry] |  |
|             | •••                        |  |
| S           | [Sector 0 Contents]        |  |
|             |                            |  |
| s+512*(n-1) | [Sector "n" Contents]      |  |

The 32-bit **Block Erase Count** contains the number of times the block has been erased. The main goal of LevelX is to keep the erase count of all blocks relatively close to help prevent any one block from wearing out prematurely. The 32-bit **Minimum Mapped Sector** and **Maximum Mapped Sector** fields are written only when all the logical sectors in the block have been mapped and written to. These fields are useful for optimization of the sector read operation. The **Free Sector Bit Map** entry is a bit map where each set bit corresponds to an unmapped sector in the

block. This field is used to make the free sector search more efficient. This is a variable length field that requires one word for every 32 sectors in the block. The **Sector Mapping Entry** array contains mapping information for each sector in the block. Each entry has the following format:

#### **Sector Mapping Entry**

| Bit(s) | Meaning                                                             |
|--------|---------------------------------------------------------------------|
| 31     | Valid flag. When set and logical sector not all ones indicates      |
|        | mapping is valid                                                    |
| 30     | Obsolete flag. When clear, this mapping is either obsolete or is in |
|        | the process of becoming obsolete.                                   |
| 29     | Mapping entry write is complete when this bit is 0                  |
| 0-28   | Logical sector mapped to this physical sector—when not all ones.    |

The upper bit of the 32-bit field (bit 31) is used to indicate the logical sector mapping is valid. If this bit is 0, the information in this entry (and corresponding sector contents) is no longer valid. The next bit - bit 30 - is used to indicate this sector is in the process of becoming obsolete and a new sector is being written. Bit 29 is used to indicate when the mapping entry write is complete. If bit 29 is 0, the mapping entry write is complete. If bit 29 is set, the mapping entry was in the process of being written. Bits 30 and 29 are used in recovering from a potential power loss while updating a new sector mapping. Finally, the lower 29-bits (28-0) contain the logical sector number for the sector. If a sector has not been mapped, all bits will be set, i.e., it will have a value of 0xFFFFFFFF.

## **NOR Driver Requirements**

LevelX requires an underlying NOR flash driver that is specific to the underlying flash part and hardware implementation. The driver is specified to LevelX during initialization via the API *Ix\_nor\_flash\_open*. The prototype of the LevelX driver is:

```
INT nor_driver_initialize(LX_NOR_FLASH *instance);
```

The "*instance*" parameter specifies the LevelX NOR control block. The driver initialization function is responsible for setting up all the other driver-level services for the associated LevelX instance. The services required for each LevelX NOR instance are:

Read Sector Write Sector Block Erase Block Erased Verify System Error Handler

#### **Driver Initialization**

These services are setup via setting function pointers in the *LX\_NOR\_FLASH* instance within the driver's initialization function. The driver initialization function also is responsible for specifying the base address of the flash, the total number of blocks, the number of words per block, and a RAM buffer for reading one sector of flash when direct flash reading is not supported (*LX\_DIRECT\_READ* is not defined). The driver initialization function likely also performs additional device and/or implementation-specific initialization duties before returning *LX\_SUCCESS*.

### **Driver Read Sector**

The LevelX NOR driver "read sector" service is responsible for reading a specific sector in a specific block of the NOR flash. All error checking and correcting logic is the responsibility of the driver service. If successful, the LevelX NOR driver returns **LX\_SUCCESS**. If not successful, the LevelX NOR driver returns **LX\_ERROR**. The prototype of the LevelX NOR driver "read sector" service is:

Where "flash\_address" specifies the address of a logical sector within a NOR flash block of memory and "destination" and "words" specify where to place the sector contents and how many 32-bit words to read.

## **Driver Write Sector**

The LevelX NOR driver "write sector" service is responsible for writing a specific sector into a block of the NOR flash. All error checking is the responsibility of the driver service. If successful, the LevelX NOR driver returns *LX\_SUCCESS*. If not successful, the LevelX NOR driver returns *LX\_ERROR*. The prototype of the LevelX NOR driver "write sector" service is:

Where "flash\_address" specifies the address of a logical sector within a NOR flash block of memory and "source" and "words" specify the source of the write and how many 32-bit words to write.

**Note**: LevelX relies on the driver to verify that the write sector was successful. This is typically done by reading back the programmed value to ensure it matches the requested value to be written.

#### **Driver Block Erase**

The LevelX NOR driver "block erase" service is responsible for erasing the specified block of the NOR flash. If successful, the LevelX NOR driver returns *LX\_SUCCESS*. If not successful, the LevelX NOR driver returns *LX\_ERROR*. The prototype of the LevelX NOR driver "block erase" service is:

Where "block" identifies which NOR block to erase. The parameter "erase\_count" is provided for diagnostic purposes. For example, the driver may want to alert another portion of the application software when the erase count exceeds a specific threshold.

**Note**: LevelX relies on the driver to examine all bytes of the block to ensure they are erased (contain all ones).

## **Driver Block Erased Verify**

The LevelX NOR driver "block erased verify" service is responsible for verifying that the specified block of the NOR flash is erased. If it is erased, the LevelX NOR driver returns *LX\_SUCCESS*. If the block is not erased, the LevelX NOR driver returns *LX\_ERROR*. The prototype of the LevelX NOR driver "block erased verify" service is:

```
INT nor driver block erased verify(ULONG block);
```

Where "block" specifies which block to verify that it is erased.

**Note**: LevelX relies on the driver to examine all bytes of the specified to ensure they are erased (contain all ones).

## **Driver System Error**

The LevelX NOR driver "system error handler" service is responsible for setting handling system errors detected by LevelX. The processing in this routine is application dependent. If it is successful, the LevelX NOR driver returns *LX\_SUCCESS*. If it is not successful, the LevelX NOR driver returns *LX\_ERROR*. The prototype of the LevelX NOR driver "system error" service is:

```
INT nor_driver_system_error(UINT error_code);
```

Where "error\_code" represents the error that occurred.

## **NOR Simulated Driver**

LevelX provides a simulated NOR flash driver that simply uses RAM to simulate the operation of a NOR flash part. By default, the NOR simulated driver provides 8 NOR flash blocks with 16 512-byte sectors per block.

The simulated NOR flash driver initialization function is Ix\_nor\_flash\_simulator\_initialize and is defined in Ix\_nor\_flash\_simulator.c. This driver also provides a good template for writing specific NOR flash drivers.

## **NOR FileX Integration**

As mentioned earlier, LevelX does not rely on FileX for operation. All the LevelX APIs may be called directly by the application software to store/retrieve raw data to the logical sectors provided by LevelX. However, LevelX also supports FileX.

The file **fx\_nor\_flash\_simulated\_driver.c** contains an example FileX driver for use with the NOR flash simulation. The NOR flash FileX driver for LevelX provides a good starting point for writing custom FileX drivers.

**Note**: The FileX NOR flash format should be one full block size of sectors less than the NOR flash provides. This will help ensure best performance during the wear level processing. Additional techniques to improve write performance in the LevelX wear leveling algorithm include:

- 1. Ensure that all writes are exactly one or more clusters in size and start on exact cluster boundaries.
- Pre-allocate clusters before performing large file write operations via the FileX fx\_file\_allocate class of APIs.
- Periodic use of *Ix\_nor\_flash\_defragment* to free up as many NOR blocks as possible and thus improve write performance.
- Ensure the FileX driver is enabled to receive release sector information and requests made to the driver to release sectors are handled in the driver by calling lx\_nor\_flash\_sector\_release.

# Chapter 6

## **LevelX NOR APIs**

The LevelX NOR APIs available to the application are:

Ix\_nor\_flash\_close
Close NOR flash instance

Ix\_nor\_flash\_defragment

Defragment NOR flash instance

Ix\_nor\_flash\_initialize
Initialize NOR flash support

Ix\_nor\_flash\_open
Open NOR flash instance

Ix\_nor\_flash\_sector\_read

Read NOR flash sector

Ix\_nor\_flash\_sector\_release
Release NOR flash sector

Ix\_nor\_flash\_sector\_write
Write NOR flash sector

## lx\_nor\_flash\_close

Close NOR flash instance

## **Prototype**

UINT lx\_nor\_flash\_close(LX\_NOR\_FLASH \*nor\_flash);

## **Description**

This service closes the previously opened NOR flash instance.

## **Input Parameters**

**nor\_flash** NOR flash instance pointer.

#### **Return Values**

**LX\_SUCCESS** (0x00) Successful request.

**LX\_ERROR** (0x01) Error closing flash instance.

**Threads** 

## Example

```
/* Close NOR flash instance "my_nor_flash". */
status = lx_nor_flash_close(&my_nor_flash);
/* If status is LX_SUCCESS the request was successful. */
```

```
lx_nor_flash_defragment, lx_nor_flash_initialize, lx_nor_flash_open,
lx_nor_flash_sector_read, lx_nor_flash_sector_release,
lx_nor_flash_sector_write
```

## lx\_nor\_flash\_defragment

Defragment NOR flash instance

#### **Prototype**

UINT lx\_nor\_flash\_defragment(LX\_NOR\_FLASH \*nor\_flash);

## **Description**

This service defragments the previously opened NOR flash instance. The defragment process maximizes the number of free sectors and blocks.

## **Input Parameters**

**nor\_flash** NOR flash instance pointer.

#### **Return Values**

**LX\_SUCCESS** (0x00) Successful request.

**LX\_ERROR** (0x01) Error defragmenting flash

instance.

**Threads** 

## Example

```
/* Defragment NOR flash instance "my_nor_flash". */
status = lx_nor_flash_defragment(&my_nor_flash);
/* If status is LX SUCCESS the request was successful. */
```

```
lx_nor_flash_close, lx_nor_flash_initialize, lx_nor_flash_open,
lx_nor_flash_sector_read, lx_nor_flash_sector_release,
lx_nor_flash_sector_write
```

## lx\_nor\_flash\_initialize

Initialize NOR flash support

## **Prototype**

UINT lx\_nor\_flash\_initialize(void);

## **Description**

This service initializes LevelX NOR flash support. It must be called before any other LevelX NOR APIs.

## **Input Parameters**

None

#### **Return Values**

LX\_SUCCESS (0x00) Successful request.
LX\_ERROR (0x01) Error initializing NOR flash support.

Initialization, Threads

## Example

```
/* Initialize NOR flash support. */
status = lx_nor_flash_initialize();
/* If status is LX_SUCCESS the request was successful. */
```

```
lx_nor_flash_close, lx_nor_flash_defragment, lx_nor_flash_open,
lx_nor_flash_sector_read, lx_nor_flash_sector_release,
lx_nor_flash_sector_write
```

## lx\_nor\_flash\_open

Open NOR flash instance

## **Prototype**

## **Description**

This service opens a NOR flash instance with the specified NOR flash control block and driver initialization function. Note that the driver initialization function is responsible for installing various function pointers for reading, writing, and erasing blocks of the NOR hardware associated with this NOR flash instance.

### **Input Parameters**

| nor_flash             | NOR flash instance pointer.              |
|-----------------------|------------------------------------------|
| name                  | Name of NOR flash instance.              |
| nor_driver_initialize | Function pointer to NOR flash driver     |
|                       | Initialization function. Please refer to |
|                       | Chapter 5 of this guide for more details |
|                       | on NOR flash driver responsibilities.    |

#### **Return Values**

| LX_SUCCESS   | (0x00) | Successful request.               |
|--------------|--------|-----------------------------------|
| LX_ERROR     | (0x01) | Error opening NOR flash           |
|              |        | instance.                         |
| LX_NO_MEMORY | (80x0) | Driver did not provide buffer for |
|              |        | reading one sector into RAM.      |

**Threads** 

## Example

```
lx_nor_flash_close, lx_nor_flash_defragment, lx_nor_flash_initialize,
lx_nor_flash_sector_read, lx_nor_flash_sector_release,
lx_nor_flash_sector_write
```

## lx\_nor\_flash\_sector\_read

Read NOR flash sector

## **Prototype**

```
UINT lx_nor_flash_sector_read(LX_NOR_FLASH *nor_flash, ULONG logical_sector, VOID *buffer);
```

### Description

This service reads the logical sector from the NOR flash instance and if successful returns the contents in the supplied buffer. Note that NOR sector size is always 512 bytes.

#### **Input Parameters**

nor\_flashNOR flash instance pointer.logical\_sectorLogical sector to read.

**buffer** Pointer to destination for contents of the

logical sector. Note that the buffer is

assumed to be 512 bytes.

#### **Return Values**

**LX\_SUCCESS** (0x00) Successful request.

**LX\_ERROR** (0x01) Error reading NOR flash sector.

**Threads** 

## **Example**

```
lx_nor_flash_close, lx_nor_flash_defragment, lx_nor_flash_initialize,
lx_nor_flash_open, lx_nor_flash_sector_release,
lx_nor_flash_sector_write
```

## lx\_nor\_flash\_sector\_release

Release NOR flash sector

## **Prototype**

## **Description**

This service releases the logical sector mapping in the NOR flash instance. Releasing a logical sector when not used makes the LevelX wear leveling more efficient.

#### **Input Parameters**

| nor_flash      | NOR flash instance pointer. |
|----------------|-----------------------------|
| logical_sector | Logical sector to release.  |

#### **Return Values**

| LX_SUCCESS | (0x00)           | Successful request.          |
|------------|------------------|------------------------------|
| IY EDDOD   | $(0 \times 0.1)$ | Error NOP flach coctor write |

**LX\_ERROR** (0x01) Error NOR flash sector write.

**Threads** 

## Example

```
/* Release logical sector 20 of the NOR flash instance
"my_nor_flash". */
status = lx_nor_flash_sector_release(&my_nor_flash, 20);
/* If status is LX_SUCCESS, logical sector 20 has been
    released. */
```

#### See Also

lx\_nor\_flash\_close, lx\_nor\_flash\_defragment, lx\_nor\_flash\_initialize, lx\_nor\_flash\_open, lx\_nor\_flash\_sector\_read, lx\_nor\_flash\_sector\_write

## lx\_nor\_flash\_sector\_write

Write NOR flash sector

## **Prototype**

```
UINT lx_nor_flash_sector_write(LX_nor_FLASH *NOR_flash, ULONG logical_sector, VOID *buffer);
```

## **Description**

This service writes the specified logical sector in the NOR flash instance.

## **Input Parameters**

| nor_flash      | NOR flash instance pointer.             |  |
|----------------|-----------------------------------------|--|
| logical_sector | Logical sector to write.                |  |
| buffer         | Pointer to the contents of the logical  |  |
|                | sector. Note that the buffer is assumed |  |
|                | to be 512 bytes.                        |  |

#### **Return Values**

| LX_SUCCESS    | (0x00) | Successful request.             |
|---------------|--------|---------------------------------|
| LX_NO_SECTORS | (0x02) | No more free sectors are        |
|               |        | available to perform the write. |
| LX_ERROR      | (0x01) | Error releasing NOR flash       |
|               | . ,    | sector                          |

**Threads** 

#### **Example**

```
lx_nor_flash_close, lx_nor_flash_defragment, lx_nor_flash_initialize,
lx_nor_flash_open, lx_nor_flash_sector_read,
lx_nor_flash_sector_release
```

# Index

| ANSI 5                                        |
|-----------------------------------------------|
| API7, 10, 38                                  |
| bad block 8, 10, 13                           |
| block erase . 9, 10, 11, 12, 37, 39, 40       |
| block management10                            |
| block status10, 13                            |
| Block Status10, 13                            |
| buffer 27, 29, 31, 32, 35, 36, 52, 53, 56, 57 |
| cache 4, 5, 6                                 |
| control block 4, 10, 25, 38, 50               |
| defragment. 5, 16, 18, 19, 20, 21, 22,        |
| 24, 26, 28, 30, 32, 34, 36, 43, 45,           |
| 46, 47, 49, 51, 53, 55, 57                    |
| ECC bytes                                     |
| erase block37                                 |
| erase count 4, 12, 37, 40                     |
| error detection8                              |
| fault tolerance4                              |
| FileX4, 5, 7, 15, 42                          |
| flash block4, 37                              |
| flash driver 4, 6, 10, 15, 25, 38, 42,        |
| 50                                            |
| flash instance. 16, 17, 18, 19, 20, 21,       |
| 22, 25, 26, 27, 28, 29, 30, 31, 32,           |
| 33, 34, 35, 36, 43, 44, 45, 46, 47,           |
| 50, 51, 52, 53, 54, 55, 56, 57                |
| flash instance pointer. 17, 19, 21, 25,       |
| 27, 29, 31, 33, 35, 44, 46, 50, 52,           |
| 54, 56                                        |

| free page                   | 9, 19, 21    |
|-----------------------------|--------------|
| free sector                 | 38, 46       |
| Hamming Error Correction    | n Codes.10   |
| initialization function 10, | 15, 25, 38,  |
| 39, 42, 50                  |              |
| LevelX NAND driver 11       | , 12, 13, 14 |
| LevelX NOR driver           | 39, 40, 41   |
| LevelX simulator            | 15           |
| logical sector 4, 6, 9, 15, | 31, 32, 33,  |
| 34, 35, 36, 37, 38, 39, 4   | 10, 42, 52,  |
| 53, 54, 55, 56, 57          |              |
| NAND flash block            | 14           |
| NAND instance               |              |
| NOR flash block37           | , 39, 40, 42 |
| NOR instance                |              |
| page erase                  | 12           |
| page size                   | 8, 31, 35    |
| read sector                 | 39           |
| sector mapping              | 4, 8, 38     |
| sector read                 | 15, 37       |
| sector size                 | 31, 52       |
| sector write                | 33, 54       |
| simulated NAND flash driv   | /er 14, 15   |
| spare bytes                 |              |
| ThreadX                     | 2, 4, 6      |
| wear leveling               | 4, 33, 54    |
| write sector                | 39           |

LevelX™ User Guide

Publication Date: Rev.5.40 Aug 28, 2018

Published by: Renesas Electronics Corporation



#### **SALES OFFICES**

## Renesas Electronics Corporation

http://www.renesas.com

Refer to "http://www.renesas.com/" for the latest and detailed information.

Renesas Electronics America Inc. 1001 Murphy Ranch Road, Milpitas, CA 95035, U.S.A. Tel: +1-408-432-8888, Fax: +1-408-434-5351

Renesas Electronics Canada Limited 9251 Yonge Street, Suite 8309 Richmond Hill, Ontario Canada L4C 9T3 Tel: +1-905-237-2004

Renesas Electronics Europe Limited
Dukes Meadow, Millboard Road, Bourne End, Buckinghamshire, SL8 5FH, U.K
Tel: +44-1628-651-700, Fax: +44-1628-651-804

Renesas Electronics Europe GmbH

Arcadiastrasse 10, 40472 Düsseldorf, Germany Tel: +49-211-6503-0, Fax: +49-211-6503-1327

Renesas Electronics (China) Co., Ltd.
Room 1709 Quantum Plaza, No.27 ZhichunLu, Haidian District, Beijing, 100191 P. R. China Tel: +86-10-8235-1155, Fax: +86-10-8235-7679

Renesas Electronics (Shanghai) Co., Ltd.
Unit 301, Tower A, Central Towers, 555 Langao Road, Putuo District, Shanghai, 200333 P. R. China Tel: +86-21-2226-0888, Fax: +86-21-2226-0999

Renesas Electronics Hong Kong Limited
Unit 1601-1611, 16/F., Tower 2, Grand Century Place, 193 Prince Edward Road West, Mongkok, Kowloon, Hong Kong
Tel: +852-2265-6688, Fax: +852 2886-9022

Renesas Electronics Taiwan Co., Ltd. 13F, No. 363, Fu Shing North Road, Taipei 10543, Taiwan Tel: +886-2-8175-9600, Fax: +886 2-8175-9670

Renesas Electronics Singapore Pte. Ltd.
80 Bendemeer Road, Unit #06-02 Hyflux Innovation Centre, Singapore 339949
Tel: +65-6213-0200, Fax: +65-6213-0300

Renesas Electronics Malaysia Sdn.Bhd.
Unit 1207, Block B, Menara Amcorp, Amcorp Trade Centre, No. 18, Jln Persiaran Barat, 46050 Petaling Jaya, Selangor Darul Ehsan, Malaysia Tel: +60-3-7955-9390, Fax: +60-3-7955-9510

Renesas Electronics India Pvt. Ltd.
No.777C, 100 Feet Road, HAL 2nd Stage, Indiranagar, Bangalore 560 038, India Tel: +91-80-67208700, Fax: +91-80-67208777

Renesas Electronics Korea Co., Ltd.
17F, KAMCO Yangjae Tower, 262, Gangnam-daero, Gangnam-gu, Seoul, 06265 Korea Tel: +82-2-558-3737, Fax: +82-2-558-5338

LevelX™ User Guide

